package codingInterview.leetcode.editor.cn;

//输入一个英文句子，翻转句子中单词的顺序，但单词内字符的顺序不变。为简单起见，标点符号和普通字母一样处理。例如输入字符串"I am a student. "，
//则输出"student. a am I"。 
//
// 
//
// 示例 1： 
//
// 输入: "the sky is blue"
//输出: "blue is sky the"
// 
//
// 示例 2： 
//
// 输入: "  hello world!  "
//输出: "world! hello"
//解释: 输入字符串可以在前面或者后面包含多余的空格，但是反转后的字符不能包括。
// 
//
// 示例 3： 
//
// 输入: "a good   example"
//输出: "example good a"
//解释: 如果两个单词间有多余的空格，将反转后单词间的空格减少到只含一个。
// 
//
// 
//
// 说明： 
//
// 
// 无空格字符构成一个单词。 
// 输入字符串可以在前面或者后面包含多余的空格，但是反转后的字符不能包括。 
// 如果两个单词间有多余的空格，将反转后单词间的空格减少到只含一个。 
// 
//
// 注意：本题与主站 151 题相同：https://leetcode-cn.com/problems/reverse-words-in-a-string/ 
//
//
// 注意：此题对比原题有改动 
// Related Topics 双指针 字符串 👍 186 👎 0

import java.util.Arrays;
import java.util.Collections;
import java.util.List;
import java.util.Stack;

//Java：剑指 Offer 58 - I - 翻转单词顺序
public class FanZhuanDanCiShunXuLcof{
    public static void main(String[] args) {
                Solution solution = new FanZhuanDanCiShunXuLcof().new Solution();
        // TO TEST
    }
    
    //leetcode submit region begin(Prohibit modification and deletion)
class Solution {
    public String reverseWords(String s) {
        s = s.trim();
        int len = s.length(), left = len-1, right=len-1;
        StringBuffer sb = new StringBuffer();
        while (left>=0){
            while(left>=0 && s.charAt(left) !=' ') left--; // 找到单词后的空格
            sb.append(s,left+1,right+1).append(" "); // 添加单词并添加空格
            while (left>=0 && s.charAt(left)==' ') left--; // 跳过多余的空格
            right=left; // 此时为下一个单词开头
        }
        return sb.toString().trim();
    }

    public void reverseWord(StringBuffer sb, int left, int right){ //反转单个单词
        while (left<right){
            char tmp = sb.charAt(left);
            sb.setCharAt(left++,sb.charAt(right));
            sb.setCharAt(right--,tmp);
        }
    }
}
//leetcode submit region end(Prohibit modification and deletion)

}
